CREATE OR REPLACE PACKAGE BODY EDIV2.Pack_?CategoriaAduana_Multiple_Traspaleo AS
/******************************************************************************
   NAME:       Pack_?Categoria_Aduana_Multiple_Traspaleo
   PURPOSE:

   REVISIONS:
   Ver        Date        Author           Description
   ---------  ----------  ---------------  ------------------------------------
   1.0        6/2/2013   Luis Antonio Lara Capetillo       Creacion del Paquete
******************************************************************************/

PROCEDURE  Aduana_Multiple_TraspaleoInsertarModificar(pnidDocumento NUMBER, pnidAduanaMultiple NUMBER, 
						pnidAgenteAduanal NUMBER, ppatente VARCHAR2, pdescripcion_mercancia VARCHAR2, 
						ppeso NUMBER, pmarca VARCHAR2, pcontenedor_Origen VARCHAR2, 
						psello_Origen VARCHAR2, particulo23 VARCHAR2, pcontenedor_Destino VARCHAR2, 
						psello_Destino VARCHAR2, pnumero_Gafete VARCHAR2, pnidEmpresaRecinto NUMBER, 
						pnidTipoTraspaleo NUMBER, pTransaccion OUT NUMBER, pMensaje OUT VARCHAR2)
AS
vExisteRegistro NUMBER(1);
BEGIN
  SELECT count(*)
  INTO   vExisteRegistro
  FROM   ediv2.Aduana_Multiple_Traspaleo
  WHERE  nidDocumento=pNidDocumento;
  
  IF vExisteRegistro=0 THEN
    INSERT INTO ediv2.Aduana_Multiple_Traspaleo
	           (nid, nidDocumento, nidAduanaMultiple, 
						nidAgenteAduanal, patente, descripcion_mercancia, 
						peso, marca, contenedor_Origen, 
						sello_Origen, articulo23, contenedor_Destino, 
						sello_Destino, numero_Gafete, nidEmpresaRecinto, 
						nidTipoTraspaleo)
    VALUES     (seq_Aduana_Multiple_Traspaleo.nextval, pnidDocumento, pnidAduanaMultiple, 
						pnidAgenteAduanal, ppatente, pdescripcion_mercancia, 
						ppeso, pmarca, pcontenedor_Origen, 
						psello_Origen, particulo23, pcontenedor_Destino, 
						psello_Destino, pnumero_Gafete, pnidEmpresaRecinto, 
						pnidTipoTraspaleo);
  ELSE
    UPDATE ediv2.Aduana_Multiple_Traspaleo
    SET    nidDocumento=pnidDocumento, nidAduanaMultiple=pnidAduanaMultiple, 
		nidAgenteAduanal=pnidAgenteAduanal, patente=ppatente, descripcion_mercancia=pdescripcion_mercancia, 
		peso=ppeso, marca=pmarca, contenedor_Origen=pcontenedor_Origen, 
		sello_Origen=psello_Origen, articulo23=particulo23, contenedor_Destino=pcontenedor_Destino, 
		sello_Destino=psello_Destino, numero_Gafete=pnumero_Gafete, nidEmpresaRecinto=pnidEmpresaRecinto, 
		nidTipoTraspaleo=pnidTipoTraspaleo
    WHERE  nidDocumento=pNidDocumento;
  END IF;
  
  COMMIT;
  pTransaccion := 1;
  pMensaje := 'Terminado OK';
  dbms_output.put_line('Terminado OK');

EXCEPTION
  WHEN OTHERS THEN
    pTransaccion := 0;
    pMensaje := 'Error en  Aduana_Multiple_Traspaleo_InsertarModificar:' || SQLCODE || ' Mensaje: ' || sqlerrm;
    dbms_output.put_line('Error en  Aduana_Multiple_Traspaleo_InsertarModificar:' || SQLCODE || ' Mensaje: ' || sqlerrm);
END;

PROCEDURE  Aduana_Multiple_TraspaleoConsultar(pNidDocumento NUMBER, pTransaccion OUT NUMBER, pCursor OUT cursor_type)
AS
BEGIN
  OPEN pCursor FOR
    SELECT nid, nidDocumento, nidAduanaMultiple, 
						nidAgenteAduanal, patente, descripcion_mercancia, 
						peso, marca, contenedor_Origen, 
						sello_Origen, articulo23, contenedor_Destino, 
						sello_Destino, numero_Gafete, nidEmpresaRecinto, 
						nidTipoTraspaleo
    FROM   ediv2.Aduana_Multiple_Traspaleo
    WHERE  nidDocumento=pNidDocumento;
    
  pTransaccion := 1;
EXCEPTION 
  WHEN OTHERS THEN
    pTransaccion := 0;
END;

PROCEDURE  Aduana_Multiple_TraspaleoDetalleXML(pNidDocumento NUMBER, pTransaccion OUT NUMBER, pEncabezado OUT cursor_type,
                           pDatos OUT cursor_type, pIncidencias OUT cursor_type)
AS
BEGIN
  OPEN pEncabezado FOR
    SELECT d.nid, d.codigo, d.fechacreacion,
           (us.nombre ||' '||us.apellidopat||' '||us.apellidomat) as nombre, d.nidusuario
    FROM   documento d, usuarios us
    WHERE  d.nid=pnidDocumento
    AND    d.nidusuario=us.nid;
    
  OPEN pDatos FOR
    SELECT nid, nidDocumento, nidAduanaMultiple, 
						nidAgenteAduanal, patente, descripcion_mercancia, 
						peso, marca, contenedor_Origen, 
						sello_Origen, articulo23, contenedor_Destino, 
						sello_Destino, numero_Gafete, nidEmpresaRecinto, 
						nidTipoTraspaleo
    FROM   ediv2.Aduana_Multiple_Traspaleo
    WHERE  nidDocumento=pNidDocumento;
    
  OPEN pIncidencias FOR
    SELECT i.fechaemision, i.descripcion, us.nombre
    FROM   incidencia i, usuarios us
    WHERE  niddocumento=pnidDocumento
    AND    i.nidusuario=us.nid;
    
    pTransaccion := 1;
    
EXCEPTION 
  WHEN OTHERS THEN
    pTransaccion := 0;
END;

--otros

END Pack_?Categoria_Aduana_Multiple_Traspaleo;
